草庐IT

c++ - auto_ptr 和 dynamic_pointer_cast

全部标签

go - 是否有可能触发 "invalid memory address or nil pointer dereference"的错误?

我有一个偶尔会崩溃的应用程序:panic:运行时错误:无效的内存地址或零指针取消引用[信号SIGSEGV:分段违规代码=0x1地址=0x20pc=0x122e64a]跟踪一直导致返回语句,该语句返回一个结构和错误。新(“一些用于调试的文本:”+err.Error())该结构似乎没有任何可以取消引用指针的内容,但我重构了该函数,因此它使用了按引用传递并且不需要返回该函数;它只返回了errors.New()。panic还是发生了。我检查了函数并对其进行了更改,因此它只返回错误,没有错误。New()字符串加上err.Error()。现在我似乎不能再引起panic了……所以问题是:关于erro

c - 尝试在 Windows 上使用 cuda

有各种依赖于cuda.h文件和cuda库(特别是ML库)的Go库。每次我尝试在Windows上安装这些库之一时,我都会收到一条错误消息fatalerror:cuda.h:Nosuchfileordirectory//#include我知道我需要做什么(将Cuda库/头文件链接到我要安装的go库),但是,我不确定如何去做,尤其是在Windows上。由于各种原因,我使用GCC而不是MSVC,但即使我尝试使用MSVC,我也遇到了同样的问题。有什么方法可以将cuda编译器/头文件直接链接到我的Go环境,或者我是否需要手动将go/cgo编译器指向保存Cuda头文件的目录,我该怎么做?我试过向一些

pointers - 将类型别名的变量传递给需要指向基础类型的指针的函数

我将自定义类型别名(使用方法)定义为:typeAwsRegionstring然后我想将这种类型的变量传递给另一个遗留(不受我控制)函数,它接受指向字符串的指针(指向基础类型的指针):funcmain(){varregionAwsRegion="us-west-2"f(®ion)//HowtoproperlycastAwsRegiontypehere?}funcf(s*string){fmt.Println(*s)//justanexample}当然我不能这样做,错误消息指出:cannotuse®ion(type*AwsRegion)astype*stringinargume

pointers - 如何更改接口(interface)参数?

我用来处理DB的库提供了方便的接口(interface)来保存/加载数据而无需强制转换Put(ccontext.Context,key*Key,srcinterface{})(*Key,error)Get(ccontext.Context,key*Key,dstinterface{})error但是,我无法理解GET方法如何工作。我尝试用最简单的代码片段复制行为,但没有成功。import"fmt"typeMyTypestruct{insidestring}funcsetVal(dst*MyType){someVal:=MyType{"new"}*dst=someVal}funcsetV

pointers - 使用非指针值调用指针接收器方法

这个问题在这里已经有了答案:XdoesnotimplementY(...methodhasapointerreceiver)(4个答案)Golangmethodwithpointerreceiver[duplicate](2个答案)MethodSets(PointervsValueReceiver)(3个答案)关闭8个月前。请看下面的代码。我知道非指针接收器可以接受指针和非指针值,但指针接收器只能接受指针值。话虽如此,我不明白最后一个电话是如何工作的,而倒数第二个电话却没有。(RunHere)问题是我能够从非指针方法调用指针接收器方法。这在othersimilarquestion中没有

c++ - 如何将 CGO 用于具有条件内联函数的头文件?

我目前正在为Capi编写一个Go包装器,其中包含带有此ifdef的header:#ifdef__cplusplus#defineTEST_INLINEinline#else#defineTEST_INLINE#endifTEST_INLINEintcallC_inline(){return1;}不幸的是,我无法更改header,因为它是第三方代码。如果我将-Wl,--allow-multiple-definition传递给链接器,代码可以正常编译,但我认为这是一种不好的做法。所以,我感兴趣的是有没有我可以传递给CGO的标志或技巧来满足#ifdef__cplusplus条件?编译异常:C

pointers - 为指针类型的字段赋值的简写是什么

这个问题在这里已经有了答案:HowdoIdoaliteral*int64inGo?(4个答案)关闭4年前。我成功了:packagemainimport"fmt"typeteststruct{A*intBstring}funcmain(){x:=1varAtestA.B="hello"A.A=&xfmt.Printf("%s,%v",A.B,*A.A)}Playground:https://play.golang.org/p/iMsFBTWkRJU我知道使用x:=1和A.A=&x已经结束了。如何修改并使其更简单?谢谢你的时间

pointers - Golang 接口(interface)和真实类型

设valuePtr和value是两个interface{}。知道valuePtr是value类型的指针,如何让valuePtr指向value?我目前使用的“技巧”适用于reflect包和类型开关:switchvalue.(type){casestring:ptr:=reflect.ValueOf(valuePtr).Elem().Addr().Interface().(*string)*ptr=value.(string)case...:[...]}这要求可以为函数提供的每种类型都有一个案例。不过,我正在使用interface{}来实现通用化。因此,这种技术最终会导致列出数十种类型的情

pointers - Golang指针反向链表混淆

我是Golang的新手,对指针在这里的工作方式有点困惑,我以反向链表问题为例。funcreverseList(head*ListNode)*ListNode{varprev*ListNode=nilfor{ifhead==nil{break}temp:=headhead=head.Nexttemp.Next=prevprev=temp}returnprev}在这种情况下,temp和head指向相同的内存位置。但是,如果我将行temp.Next=prev放在head=head.Next之前,head.Next将指向nil。当我们说temp.Next=prev时,幕后发生了什么。我们是说t

go - 我如何解码 Dynamic Viper 或 JSON 键作为结构字段的一部分

当JSON不是“所需”格式时,我发现GOLANG中的编码(marshal)处理和解封处理非常困惑。例如,在一个JSON配置文件(我正在尝试将其与Viper一起使用)中,我有一个如下所示的配置文件:{"things":{"123abc":{"key1":"anything","key2":"more"},"456xyz":{"key1":"anything2","key2":"more2"},"blah":{"key1":"anything3","key2":"more3"}}}其中“事物”可能是另一个对象中的对象n层以下我有一个结构:typeThingstruct{Namestring